package multimode;

/**
 * 三、简单多状态 dp 问题
 * 3. 删除并获得点数
 * 2024-10-21
 */
public class demo13 {
    public int deleteAndEarn(int[] nums) {
        //1. 预处理
        int n = 10001;
        int[] arr = new int[n];
        for (int x : nums)
            arr[x] += x;

        //2. 创建 dp 表
        int[] f = new int[n];
        int[] g = new int[n];

        //3. 初始化
        f[0] = arr[0];

        //4. 填表
        for (int i = 1; i < n; i++) {
            f[i] = g[i-1] + arr[i];
            g[i] = Math.max(f[i-1], g[i-1]);
        }
        return Math.max(f[n-1], g[n-1]);
    }
}
